# Aurora 活用 チュートリアル

## ~Xilinx 社の FPGA 間通信プロトコルを 使いこなす

久保田新二

ここでは、FPGA 間インターフェースで用いるデータ・リン ク層通信プロトコルの一つである米国 Xilinx 社の「Auroral の活用法を解説する. Aurora 通信ブロックの生成方法やユー ザ論理とのインターフェース法、検証手法について具体的に説 明する. (編集部)

Aurora は、米国 Xilinx 社のデータ・リンク層通信プロ トコルです、FPGA が搭載する高速シリアル通信ブロック RocketIOのMGT ブロックを使用します(図1). 通信した いデータにヘッダとフッタを自動的に付加して送受信を行 います(図2).

| SCP | Data<br>0 | Data<br>1 | Data<br>2 |  |  | Data<br>N-1 | Data<br>N | ECP |  |
|-----|-----------|-----------|-----------|--|--|-------------|-----------|-----|--|
|-----|-----------|-----------|-----------|--|--|-------------|-----------|-----|--|

図2 シリアル・データのパケットのイメージ

通信したいデータにヘッダとフッタを自動的に付加する.

RocketIOのMGT ブロックは, さまざまなシリアル通信 仕様に柔軟に対応しています.しかし,特性の設定やデー タ同期への考慮が難しいため,とても使用しにくいもので す.これを簡単に使用できるように開発されたプロトコル が, Auroraです.

Aurora モジュールは, Xilinx 社の FPGA 開発ツールの 一つで、IPコアの設定・生成を行う「CORE Generator」を 使って作成します、ウィザードに従ってユーザ・インター フェースのパラメータと通信速度の値を設定していくだけ です.難しいMGTの設定は自動で行ってくれるので,設 計者はMGTをほとんど意識せずに高速シリアル通信回路 を設計できます.後はAurora通信ブロックに対し,送受 信したいデータを Aurora で決められたユーザ・インター フェースの仕様通りのタイミングで受け渡しすればよいの です.



#### 図1 Aurora を使ったシステム構成

米国 Xilinx 社の FPGA が搭載する高速シリアル通信プロック RocketIO の MGT プロックを使用する.

KeyWord

FPGA, 高速シリアル通信, RocketIO, Aurora, CORE Generator, MGT, クロック・コレクション, クロック リセット, ModelSim

しかし,このインターフェースの仕様を正しく理解していないと,予想外の事態を引き起こす可能性があります.

#### 1. 高速シリアル通信ブロック活用の基礎

Auroraを使用すれば、設計者はMGTをほとんど意識せずに設計を行えると述べました.しかし、MGTの基本構成を全く知らずに設計はできません.ここではVirtex-4をターゲットに、Auroraの設計に必要な最低限の知識についてまとめます.

#### ● MGTの構成

MGT は FPGA の品種によって搭載数が異なります.また,MGT と接続されるシリアル信号線も専用ピンとして決められており,パッケージによって異なります.

Virtex-4では、物理的にMGT は左右に分かれて配置されています(図3).同様に、MGT へ供給するクロック・ドライバも左右それぞれに配置されています。この物理的要因から、供給するリファレンス・クロックは、左右それぞれにある MGT では共通に使用可能ですが、左右にまたがる MGT で共有することはできません。

MGT は2個(MGTA, MGTB)で一つのMGTタイル(ペア)を構成しています.そのためMGTタイルの片側のMGTのみを使用する場合,それとペアとなっているMGTには未使用の処理が必要になります.CORE GeneratorでAuroraを作成したときに,一緒に出力されるunused\_mgtというモジュールを組み込みます.さらにペアのMGT同士のコミュニケーション用にCOMBUSIN,COMBUSOUTという信号があるので,互いに接続する必要があります.

#### ● クロック・コレクションの動作

クロック・コレクションとは,対向して接続された Auroraの送信側から一定サイクル期間内にアイドル・シーケンスを挿入する処理のことです.

MGT の受信側には、受信データを一時蓄えるためのエラスティック・バッファという FIFO メモリが存在しています.このバッファは、書き込みと読み出しのクロックが異なります.書き込みは受信データから抽出したクロックで、読み出しはユーザ・インターフェースから供給されたクロックにて行われます.SerDes チップの場合では、受信



図3 MGT の構成

Virtex-4 では,物理的にMGT は左右に分かれて配置されている.MGT へ供給するクロック・ドライバも左右それぞれに配置されている.MGT は2個(MGTA,MGTB)で一つのMGT タイル(ペア)を構成する.

側は従属モードとして受信したデータから抽出したクロックをユーザ・インターフェースで使用しますが,ここではクロックの乗せ換えを行っているようです.

送信側と受信側で同じ仕様の水晶発振器を使用していても、水晶発振器の精度の範囲で周波数が異なります.従って、これが原因で受信側のエラスティック・バッファにオーバフローまたはアンダフローが生じる可能性があります.すると、HARD\_ERRORに至って、Lane\_UPとChannel\_UPがダウンし、通信が途切れてしまいます.

この問題を回避するため、一定期間内にアイドル・シーケンスを送信するサイクルが必要になります.これが送信側からのクロック・コレクションです.クロック・コレクションは、Auroraの入力ポートにあるDO\_CC信号を一定期間以上アサートすることによって行います.Lane\_UP、Channel UP確立後から常に必要なサイクルです.

クロック・コレクションのアサート間隔とアサート期間は,ユーザ・インターフェースのデータ幅や水晶発振器の精度によって異なります.100ppm(ppmは百万分の1)精度では表1のようになります.

クロック・コレクションを挿入するためのタイミング設



表1 クロック・コレクションのアサート間隔とアサート期間

| レーン幅 | DO_CC のアサート間隔<br>(User_CLK サイクル) | DO_CC アサート期間<br>(User_CLK サイクル) |  |  |
|------|----------------------------------|---------------------------------|--|--|
| 2バイト | 5000                             | 6                               |  |  |
| 4バイト | 3000                             | 3                               |  |  |

#### 計には注意が必要です.

Aurora モジュールでは,DO\_CC 信号をアサートされている間,送信側は TX\_DST\_RDY\_N 信号がデアサートされ、ユーザ・データの送信ができません( **図**4). 送信中であれば,クロック・コレクションの挿入を優先します.受信側は RX\_SRC\_RDY\_N 信号がデアサートされ,この期間は待ち状態にしなければなりません.クロック・コレクションはユーザ・データの送信よりも優先順位が高いため,データ送信中に割り込むことになります.

ユーザ・インターフェースから Aurora モジュールへ出力したデータが,実際にシリアル・データとして出力されるまでに5クロックの遅延があります.従って,フレーム・データの受信とクロック・コレクションが重複しないためには,送信終了後(EOF出力後)5クロック以上あけてからDO CC信号をアサートする必要があります.

#### 2. Aurora モジュールの生成

ここでは、表2に示すツールを使用して、Aurora モジュールを組み込む手順を具体的に説明します.

表2 Aurora モジュールの生成・検証ツール

| 種類         | ツール名                                                                                        |
|------------|---------------------------------------------------------------------------------------------|
| FPGA 開発ツール | ISE 8.1 Service Pack3( WebPACK では使<br>用できない)<br>CORE Generator<br>IP Update 1( Aurora V2.4) |
| シミュレータ     | ModelSim SE 6.1a                                                                            |



図5 Aurora コアの入手

Xilinx 社のWeb サイト( http://www.xilinx.co.jp/aurora/register\_aurora.htm )でユーザ登録を行う.ライセンス・ファイルは電子メールで届く.

#### ● Aurora コアの入手

Auroraを使用するためには, Xilinx 社の Web サイト (http://www.xilinx.co.jp/aurora/register\_aurora.htm) でユーザ登録を行います(**図**5). ユーザ登録は無料です.

ユーザ登録が完了すると,電子メールでライセンス・ファイルが届きます.ラインセンス・ファイルは圧縮されているので,解凍した上でISEがインストールされているフォルダ先(例えば,¥Xilinx¥coregen¥core\_licenses¥)にコピーするとAuroraが使用できるようになります.

CORE Generatorの起動



**図**6 CORE Generator **による**Aurora **モジュールの生成** FPGA 開発ツールの ISE に含まれている CORE Generator を使用する.

#### ● CORE Generator による Aurora モジュールの生成

FPGA 開発ツールの ISE に含まれている CORE Generator を起動します. Aurora が正しくインストールされていると CORE Generator の IP Name の横の License 表示のマークの"S"が外され, Aurora モジュールを作成できるようになります(図6).

「Aurora」の文字をダブル・クリックすると,メッセージが表示されます.ライセンスを取得済みであれば,無視してかまいません.その後,ウィザード画面が表示される

ので,画面に従って各パラメータの設定を行います.

#### 1)1ページ目の設定画面

Component Name 欄に作成する Aurora モジュールのモジュール名を入力します.ここで入力したモジュール名と同じフォルダ名の下にファイルが生成されます.

Target Deviceのリストでは,使用する品種を選択します.

HDL 欄では,使用する設計言語を選択します. Aurora Lanes 欄には,1チャネル内で使用するレーン数



**図**6 CORE Generator **による** Aurora **モジュールの生成(つづき)** FPGA 開発ツールのISE に含まれている CORE Generator を使用する.

を入力します. Lane Width では,1レーン当たりのユーザ・インターフェースのデータ幅を選択します. 単位はバイトです. Interface 欄ではデータ転送のインターフェースを選択します.

Special Features は , 別の使い方をする場合のみチェック します .

#### 2)2ページ目の設定画面

Line Rate 欄は,シリアル・データの通信速度を設定しま

す.単位はGbpsです. Select Reference Clock Frequency in MHz は, Auroraに供給するリファレンス・クロックの周波数を選択します. Line Rateの値に応じて設定できる周波数は決められるのでリストから選択します.

#### 3)3ページ目の設定画面

ウィザードの3ページ目では,リファレンス・クロック・ ソースを選択します.Col.0とCol.1は,前に述べた(**図**3) 左右にあるMGTのロケーションを示します.Col.0は左側,

### け 集 LSI間をつなぐ 2 高速インターフェース・テクニック



**図**6 CORE Generator **による**Aurora **モジュールの生成(つづき)** FPGA 開発ツールのISE に含まれている CORE Generator を使用する.

- DX 🖿 aurora\_2byte ファイル(E) 編集(E) 表示(V) お気に入り(A) ツール(T) ヘルプ(H) クロック・コレクションの制御を行う参考回路 DCMが組み込まれているソース・ファイル アドレス(D) 🛅 D:¥Work¥coregen¥aurora\_2byte Auroraにユーザ・クロックに同期した半分の周波数の cc\_manager クロックを供給するためのモジュール(2バイト・レーンのみ) ファイルとフォルダのタスク clock module 🚽 新しいフォルダを作成する 送信側でテスト・パターンを生成し、 acripts 🗕 るのフォルダを Web に公開する 受信側でそのパターンをチェックする \_src → □ このフォルダを共有する サンプル回路 🗎 testbench 🗻 ucf aurora\_gs\_ug173.pdf サンプル回路のシミュレーション・データなど その他 readme.txt release\_notes.txt a coregen ug061.pdf Auroraモジュールのソース・ファイル □ マイドキュメント 任意で付けたモジュール名のファイルがTOPになる 一 共有ドキュメント 下位ソース・ファイルは、そのまま使用する 🖳 マイコンピュータ マイ ネットワーク サンプル回路のテストベンチ 詳細 × 制約ファイル

図7 生成された Aurora モジュールのファイル

HDLソース・ファイルや Xilinx 社の評価ボード「MK421 ボード( Virtex-4 RocketIO Characterization Platform )」用のサンプル回路やテストベンチなども出力される.

Col.1 は右側に相当します.左右どちらのMGTを使用するかによって,リファレンス・クロックの配置もそれに合わせて設定します.さらに,その中でどのクロック線を使用するか選択します.REF\_CLK1とREF\_CLK2は,通信速度が1Gbps以上のときに使用します.GREF\_CLKは,通

信速度が1Gbpsよりも低速のときに使用します.

MGT Placement は,選択したデバイスにおいて使用する MGT の物理配置を示します.使用する MGT に,番号を1から Aurora Lanes で設定した数まで入力します(未使用 MGT には X のままにする).ここで指定した配置は,生



| 生成ファイル名                    | 2バイト・<br>インターフェース | 4パイト・<br>インターフェース | 共通性   | 生成ファイル名                    | 2バイト・<br>インターフェース | 4バイト・<br>インターフェース | 共通性     |
|----------------------------|-------------------|-------------------|-------|----------------------------|-------------------|-------------------|---------|
| aurora_2byte.vhd           |                   | -                 | (TOP) | output_switch_control.vhd  | -                 |                   | -       |
| aurora_4byte.vhd           | -                 |                   | (TOP) | rx_ll.vhd                  |                   |                   |         |
| aurora_lane.vhd            |                   | -                 | -     | rx_ll_deframer.vhd         | -                 |                   | -       |
| aurora_lane_4byte.vhd      | -                 |                   | -     | rx_ll_pdu_datapath.vhd     |                   |                   |         |
| aurora_pkg.vhd             |                   |                   |       | rx_ll_ufc_datapath.vhd     |                   |                   |         |
| cal_block_v1_2_1.vhd       |                   |                   |       | sideband_output.vhd        | -                 |                   | -       |
| channel_error_detect.vhd   |                   |                   |       | storage_ce_control.vhd     | -                 |                   | -       |
| channel_init_sm.vhd        |                   |                   |       | storage_count_control.vhd  | -                 |                   | -       |
| chbond_count_dec.vhd       |                   | -                 | -     | storage_mux.vhd            | -                 |                   | -       |
| chbond_count_dec_4byte.vhd | -                 |                   | -     | storage_switch_control.vhd | -                 |                   | -       |
| error_detect.vhd           |                   | -                 | -     | sym_dec.vhd                |                   | -                 | -       |
| error_detect_4byte.vhd     | -                 |                   | -     | sym_dec_4byte.vhd          | -                 |                   | -       |
| global_logic.vhd           |                   |                   |       | sym_gen.vhd                |                   | -                 | -       |
| idle_and_ver_gen.vhd       |                   |                   |       | sym_gen_4byte.vhd          | -                 |                   | -       |
| lane_init_sm.vhd           |                   | -                 | -     | tx_II.vhd                  |                   |                   |         |
| lane_init_sm_4byte.vhd     | -                 |                   | -     | tx_ll_control.vhd          |                   |                   |         |
| left_align_control.vhd     | -                 |                   | -     | tx_ll_datapath.vhd         |                   |                   |         |
| left_align_mux.vhd         | -                 |                   | -     | unused_mgt.vhd             |                   |                   |         |
| mgt_wrapper.vhd            |                   |                   |       | valid_data_counter.vhd     | -                 |                   | -       |
| output_mux.vhd             | -                 |                   | -     |                            | : 生成されるフ          | アイル名は同じだか         | が、中身が異な |

(c)2バイト・インターフェースと4バイト・インターフェースのファイルの共通性

#### 図8 Aurora モジュールのソース・ファイルの構成

同じファイル名でも機能が異なるものがあるので、1チップ内に複数のモジュールを実装する場合には注意が必要.

成されるサンプルの制約ファイル( ucf ファイル )に盛り込まれるだけで,後で制約ファイルを変更できるので気にする必要はありません.

最後に[ Generate ]ボタンをクリックすると,モジュール名と同じディレクトリに Auroraのファイルがいくつか生成されます.

#### ● ファイル構成

CORE Generatorでは, HDLソース・ファイルが生成されます(p.67の**図**7).また, HDLソース・ファイルのほかに, Xilinx社の評価ボード「MK421ボード(Virtex-4 RocketIO Characterization Platform)」用のサンプル回路やテストベンチなども出力されるので,初めて設計する際の参考になります.

CORE Generator で作成される Aurora モジュールのソース・ファイルの構成を**図**8 に示します. データ幅や仕様

が異なる Aurora を1チップの FPGA 内に複数エントリする際, Aurora モジュールの内部で呼び出しているコンポーネントが重複してしまう問題が発生します.1チップ内に複数の Aurora モジュールを実装する場合は,同一のファイル名(コンポーネント名)で,共通性のないものはユニークな名前に変更する必要があります.

#### 3. ユーザ回路との接続

CORE Generator で生成されたファイルをユーザ回路と接続する方法をサンプル回路を基に説明します.

サンプル回路の構成を**図**9に示します.サンプル回路を動作させるだけであれば,クロックとリセットを供給するだけで済んでしまいます.従って,まずシリアル信号線の品質のチェックを行うには,これを組み込んでチェックするとよいでしょう.



図9 Aurora モジュールを使用したサンプ ル回路

クロックとリセットを供給するだけで動作する.



INST GT11CLK\_MGT\_LEFT LOC = GT11CLK\_X0Y1;
INST GT11CLK\_MGT\_LEFT SYNCLK1OUTEN = ENABLE;
INST GT11CLK\_MGT\_LEFT SYNCLK2OUTEN = DISABLE;

(c) REFCLK1を使用する場合の設定例

図10 リファレンス・クロックの接続

GT11CLK\_MGTは使用する入力ピンに対応してチップ内の配置が決まっているので制約ファイルで設定する.

#### ● リファレンス・クロック

Auroraへ供給するリファレンス・クロックには,3通りの接続方法があります.

- MGTCLK ピンより供給(1Gbps以上で使用,ジッタ特性に優れている)
- FPGA 内で生成した信号より供給(1Gbps以下で使用可)
- GREFCLK ピンより供給(1Gbps以下で使用可能) 通信速度によって使用できるクロック線が異なるので注 意が必要です.

サンプル回路では、水晶発振器から MGTCLK ピンに供給してMGT 専用のクロック・ドライバ GT11CLK\_MGT )を介して接続しています。クロック・ドライバは、Xilinx社の unisim ライブラリに用意されているものです。GT11CLK\_MGT からは2系統のクロックを出力できますが、CORE Generatorの生成(リファレンス・クロック・ソースの選択)において、選択したクロックと同じ信号を接続するために属性の設定をします。また、GT11CLK\_MGT は使用する入力ピンに対応してチップ内の配置が決まっているので、制約ファイルで設定します(図10)。

#### ● ユーザ・クロック

ユーザ論理と Aurora との間のデータのやりとりを行う クロック( USER\_CLK )は, Aurora から出力される送信クロック( TX\_OUT\_CLK )から生成します. TX\_OUT\_CLK の周波数は,送信レートとユーザ・インターフェースのデータ幅によって次のように求められます.

●2バイト時: TX\_OUT\_CLK =(送信レート/40)×2

●4バイト時: TX\_OUT\_CLK =(送信レート/40) 送信レートが3.125Gbps,ユーザ・インターフェースが 2バイトの場合であれば,

TX\_OUT\_CLK =(3125/40)×2 = 156.25[MHz] となります.

ユーザ・インターフェースのデータ幅によってユーザ・ クロックの生成方法が異なります.

2バイトのデータ幅の場合を図11に示します.USER\_CLKと,このクロックに同期した半分の周波数のクロック(SYNC\_CLK)の2系統のクロックが必要です.TX\_OUT\_CLKをCLOCK\_MODULE(DCM)に入力して,TX\_OUT\_CLKと同じ周波数のクロック(USER\_CLK)と分周したクロックを供給します.CORE Generatorで生成されたサンプル回路(clock\_module)をそのまま流用できます.また同一仕様のAuroraを複数使用する場合で,配置が左右のどちらか一方だけであれば,ユーザ・クロックは共有して使用できます.Aurora回路ごとにDCMを1個ずつ使用してしまうと,DCMのリソースが足りなくなってしまうので,できるだけ共有した方がよいでしょう.

4バイトのデータ幅の場合を**図**12に示します.SYNC\_CLK は必要ないため,TX\_OUT\_CLKをループさせてUSER\_CLKに接続します.図では,BUFGを挿入していますが,特に意識して入れなくてもISEで自動的に挿入してくれます.

#### DCLK

Auroraのユーザ・ガイドには掲載されていませんが,



図11 2パイト・レーン時のユーザ・クロック

USER\_CLK とこのクロックに同期した半分の周波数のクロック(SYNC\_CLK)の2系統のクロックが必要.TX\_OUT\_CLKをCLOCK\_MODULE(DCM)に入力してTX\_OUT\_CLKと同じ周波数のクロック(USER\_CLK)と分周したクロックを供給する.

DCLK ピンに25MHz ~ 50MHz のクロックを供給しなければなりません .

リファレンス・クロックやユーザ・クロックとは別に、DRP ( Dynamic Reconfiguration Port )と同じクロック線を使用して、常に動作しているクロックを供給する必要があります。これはMGT と接続している Calibration Blockというモジュールに供給されて NBTI 対策などに使用されるものです。また、このクロックの周期を Auroraの TOPモジュールの Generic 文に設定する必要があります。50MHz のクロックを接続した場合は、以下のようになります( 単位はns )。

DCLK\_PERIOD\_NS\_P : integer := 20;

#### ● リセット信号

リセット信号は3種類あり,それぞれ以下の用途に使用 します.

#### PMA\_INIT

MGTの内部にあるPMAと呼ばれるアナログの部分を初期化します。電源投入時からアサートしておかなければなりません。

#### • RESET\_CALBLOCKS

MGTと接続している Calibration Block モジュールを初期化します. ユーザ・ガイドに載っていないので注意が必要です.

#### • RESET

Auroraのプロトコル関係のモジュールの初期化を行います.



**図**12 4**バイト・レーン時のユーザ・クロック**TX\_OUT\_CLKをループさせてUSER\_CLKに接続する.

リセットを解除するには、PMA\_INIT RESET\_CALBLOCKSの順番で行います。RESET信号はどのタイミングでも問題ないようです。Auroraは初期化シーケンスが定義されているので、結果的にMGTが正常な受信状態になるまでステートが動かないからです。

#### ● ユーザ・インターフェース

ユーザ論理から Aurora 回路を制御するためのインターフェースを , **表**3に示します . データの送受信は , タイミングに合わせて制御を行います .

#### ● Generic 文の設定変更

Auroraの TOP モジュールには, いくつかの Generic 文の設定が必要です.この中で設定が必要な項目を**表**4にまとめます.

#### ● 未使用のMGTの扱い

MGT2個(MGTA, MGTB)で一つのMGTタイル(ペア)を構成しているので,片側のMGTのみを使用する場合,未使用側にunused\_mgtモジュールを接続してMGTを保護する必要があります.未使用モジュールのソース・ファイルも,CORE Generatorで自動生成されます.ただし,どちらのMGTも使用しない場合は不要です.

インターフェースの信号は, Aurora モジュールと同じ信号名のものは, Aurora モジュールと同じように接続するだけです.

#### ユーザ論理から Aurora 回路を制御するためのインターフェ ース

| 信号名          | 入出力    | 詳細                    |
|--------------|--------|-----------------------|
| TX_D         | Input  | 送信データ・バス              |
| TX_SOF_N     | Input  | 送信パケットの先頭データを指定       |
| TX_EOF_N     | Input  | 送信パケットの最終データを指定       |
| TX_REM       | Input  | 送信パケットの最終データの有効バイトを指定 |
| TX_SRC_RDY_N | Input  | 有効な送信データであることを指定      |
| TX_DST_RDY_N | Output | シリアル側の送信準備ができていることを示す |

(a) データ送信時に使用

| 信号名          | 入出力    | 詳細                    |
|--------------|--------|-----------------------|
| RX_D         | Output | 受信データ・バス              |
| RX_SOF_N     | Output | 受信パケットの先頭データを示す       |
| RX_EOF_N     | Output | 受信パケットの最終データを示す       |
| RX_REM       | Output | 受信パケットの最終データの有効バイトを示す |
| RX_SRC_RDY_N | Output | 有効な受信データであることを示す      |

(b) データ受信時に使用

| 信号名         | 入出力    | 詳細                       |
|-------------|--------|--------------------------|
| CHANNEL_UP  | Output | 通信が確立していることを示す           |
| LANE_UP     | Output | レーンの初期化が完了していることを示す      |
| SOFT_ERROR  | Output | 受信データにエラーが発生したことを示す      |
| FRAME_ERROR | Output | フレームやプロトコル・エラーが発生したことを示す |
| HARD_ERROR  | Output | 通信上,致命的なエラーが発生したことを示す    |
| LOOPBACK    | Input  | ループバックの設定                |
| POWER_DOWN  | Input  | MGTの電源断を設定               |

(c)ステータスなど

表4 TOP モジュールの変更

| Generic <b>文の記述</b>                                                 | 説明                                                                                        |
|---------------------------------------------------------------------|-------------------------------------------------------------------------------------------|
| SIMULATION_P : integer := 0;                                        | 通常はデフォルトの' 0 'のままでよい .<br>シミュレーションするときに' 1 'を設定すると初期化<br>時のLane_UPまでのシミュレーション時間を短縮で<br>きる |
| LANEO_GT11_MODE_P : string := "A";<br>LANEO_MGT_ID_P : integer := 0 | 2個で一つのタイルを構成しているMGTのうち,<br>A側を使用する場合はそれぞれ"A",0の設定をし,<br>B側を使用する場合は"B",1の設定にする             |
| <pre>DCLK_PERIOD_NS_P : integer := 20;</pre>                        | DCLK に供給するクロックの周波数を設定する                                                                   |

#### ● データ送信のタイミング

制御信号に合わせて送信データを Aurora に入力します (**図**13). TX\_SOF\_N で先頭データを, TX\_EOF\_N で最 終データを指定します.TX\_SRC\_RDY\_NとTX\_DST\_ RDY\_Nが両方ともアサートされているときに,データが シリアルから送信されます.TX\_DST\_RDY\_N がデアサ ートされているときはデータの送信を一時停止させなけれ ばなりません.

#### ● データ受信のタイミング

Aurora から制御信号に合わせて受信データを出力して きます( **図**14 ). RX\_SOF\_N で先頭データを , RX\_EOF\_ Nで最終データを指定します.RX\_SRC\_RDY\_Nで有効な 受信データであることを指定します.

NFC(Native Flow Control)またはUFC(User Flow Control )を使用しない場合に送受信においてデータが待た される要因は,基本的にクロック・コレクションしかあり ません.しかし,例外があります.Auroraのユーザ・デ ータ幅が4バイト・レーンでは,RX\_SRC\_RDY\_N信号は 受信フレームの終わりから1サイクル前に必ずデアサート されます.

これは送信するデータにSCPとECPを付加するためで す.TX DST RDY がデアサートされるのと同様に,受信 したパケットからデータなどを分離する際のレイテンシの

## LSI間をつなぐ 高速インターフェース・テクニック





#### **図**15 **制約ファイルの**設定

使用するボードに合わせてucfファイルを編集する.

問題でRX\_SRC\_RDYがデアサートされるようです.

SCPやECPは,もともと2バイトで定義されているので,2バイト・インターフェースの受信ではEOPの前にRX\_SRC\_RDYをデアサートすることなくインターフェースできます.しかし,4バイトの場合だとクロック・サイクルが半分になってしまうので,このような現象になってしまうようです.

#### ● 制約ファイルの設定

各種の制約を ucf ファイルに設定します. CORE Generator で生成されたファイルを参考にしてください. ただし, aurora\_sample.ucf ファイルは, Xilinx 社の評価ボー

ド「MK421 ボード」をターゲットにしたものなので,使用するボードに合わせて ucf ファイルを編集します(**図**15).

●ロケーションの設定

MGT(GT11)とMGT専用のクロック・ドライバ(GT11\_CLK)のロケーションを設定します.

● クロック周波数設定 使用するリファレンス・クロック,ユーザ・クロック, DCLK のそれぞれの周波数の制約を設定します.

#### ● ピン配置の設定

Virtex-4 は , デフォルトの入出力ピンのレベルが LV CMOS\_25 です . このため , 通常使用している 3.3V レベルのインターフェースでは , 各ピンを LVTTL に設定する必

```
Set to fs, ps, ns, us, ms, or sec with optional prefix of 1, 10, or 100.
                                                 Resolution = psに変更
...(中略)
; Specify whether paths in simulator commands should be described
; in VHDL or Verilog format. For VHDL, PathSeparator = /
; for Verilog, PathSeparator = .
PathSeparator = / ◄
                                            行頭に;を追加してコメントにする
...(中略)
; List of dynamically loaded objects for Verilog PLI applications
追加
...(中略)
                                                                 追加
: Logic Modeling's SmartModel SWIFT software (Windows NT)
                                                                 追加
libsm = $MODEL TECH/libsm.dll
libswift=$LMC HOME/lib/pcnt.lib/libswift.dll→
```

図16 ModelSim **を使うための** modelsim.ini ファイ

ルの編集

このほかに , ライブラリの追加や環境変数の設定も 必要 .

要があります.また,Auroraのシリアル信号線は,MGTの配置を設定していれば,ピン設定を行わなくても済むようです.設定する場合,レベルはLVDS\_25にします.

#### ● コンパイル時の注意

CORE Generator から生成されたソース・ファイルやサンプル・ファイル一式を ISE のプロジェクトに追加してコンパイルを実行します.

Generating Programming fileを実行すると,シリアル信号線に関して警告メッセージが表示されますが,配置配線(PAR)にて完全に配線が完了している場合は問題ないようです.

#### 4. 検証手法

MGT を含む設計を検証するためには, SmartModel がインストールされ, SWIFT インターフェースをサポートするシミュレータが必要です.

ここでは米国 Mentor Graphics 社の ModelSim を使った シミュレーションの方法を説明します.

#### ■ ModelSim によるシミュレーション

ModelSim は, SE 版およびPE 版(オプションで付加)が サポートされますが,この機能を使用するためにはデフォ ルト設定を変更する必要があります. Windows 版以外は, Xilinx 社のアンサーシートを参照してください.

まず, Xilinx ライブラリ( unisim/simprim/Xilin

xCoreLib )を設定します.「File」「New」「Library」により, ISE がインストールされているフォルダからライブラリを追加します.

次に、modelsim.iniファイルを**図**16のように編集します。 さらに、環境変数の設定を行います。Windowsのスタート・メニューから「設定」「コントロール・パネル」を開きます。システムの「詳細設定」タブにある「環境変数」ボタンをクリックし、ユーザ環境変数PATHに以下を追加します。

%LMC HOME%¥lib¥pcnt.lib

また,システム環境変数「LMC\_HOME」が,例えば以下のように設定されていることを確認します.

C:\Xilinx\smartmodel\nt\sinstalled nt

ModelSimを起動して、ModelSimのコマンド・ウィンドウで、次のコマンドを入力してエラーが表示されていなければ、シミュレータは正しく設定されています(Warning は表示される).

VSIM> vsim unisim.ppc405

これまでの設定でシミュレータは動作しない場合があります.その場合, ModelSimのプロジェクト・ファイル(プロジェクト名.mpf)をテキスト・エディタで開いて,上記(1)~(3)の設定を直接編集してしまいましょう.それでもエラーが表示される場合は別に原因がありそうです.

Auroraのモジュールをシミュレーションするには,作成されたソース・ファイルをそのまま使用できるわけではないので注意が必要です.

Lane\_UPまでのシミュレーション時間を短縮させるため

## LSI間をつなぐ 高速インターフェース・テクニック

に, Aurora モジュールの Generic の設定値を '1 'に変更します.

リファレンス・クロックの周波数設定は,通信レートを10,20,40で割った値になるように設定しなければなりません.この設定値になっていないとLane\_UPが確立できません.例えば,通信速度が3.125 Gbpsであれば,使用できるリファレンス・クロックは次の値になります.

- 312.5MHz(10分の1)
- 156.25MHz(20分の1)

そのほかの値に設定してしまうと,シミュレーションできません.

#### ● 実機による動作試験

実機による動作試験は,まずループバック試験でシリアル信号線の品質を確認します.

シリアル信号線がケーブルへ接続されているのであれば、送信と受信をクロスで結んでループバックします.プリント基板上で接続されているのであれば、片側の Aurora はユーザ・インターフェースで受信データをそのまま送信データに接続してループバックさせるように作成します.また、単独で試験を行うのであれば、Loopback 信号の設定をSerial Loopback モードに変えて確認する方法もあります.

いずれの方法にしても,最初に確認するのはLane\_UPとChannel\_UPが確立されていることです.これが確立していなければ,何の通信試験も行えません.初期化状態からずっと確立していないのであれば,クロックやリセット信号が疑われます.確立と切断を繰り返しているようであれば,クロック・コレクションの挿入方法,または信号品

質などの問題で通信不良が発生していることが考えられます.この判断方法としては,HARD\_ERRORが発生する前に,MGTのコアの信号であるRXNOTINTABLE(8b/10bデコード・エラー)あるいはRXDISPERR(ディスパリティ・エラー)信号がアサートされているようなら,信号品質の問題と思われます.

また、テスト・パターンを使った通信試験では問題なく動作していても、実データの通信試験を開始するとHARD\_ERRORが発生して、時々Lane\_UPが切断されてしまうこともあります。テスト・パターンとデータの遷移状態が異なるために、このようなことも起こり得るので十分に注意が必要です。

#### ● まとめ

Auroraは、シリアル通信のインターフェースを CORE Generatorで自動生成します.また、ユーザ・インターフェースも比較的単純です.このおかげで、FPGA の設計はそれほど難くありませんでした.しかし、工程を進めて行くうちにコンパイルでエラーが発生する、シミュレータが起動しない、実機動作ではLane\_UP ができないなど、次々と難題が襲ってきました.これらは、MGT の構成や使い方などを知っていれば、難なく解決できるものがありました.ここでは、それらに陥らないためのポイントについて述べてきたつもりなので、参考になることを願っています.

くぽた・しんじ 中央システム技研(株)

Design Wave Mook

好評発売中



動作原理、設計・製造工程から応用事例まで

## MEMS 開発&活用スタートアップ

Design Wave Magazine編集部 編 B5変型判 216ページ 定価 2,520円(税込) ISBN4-7898-3716-5

「MEMS( micro electoro mechanical system )」や「シリコン・マイクロマシン」といったことばをよく耳にするようになりました.実際,この技術を応用したデバイスは,インク・ジェット・プリンタや自動車のエア・バッグ・システム,プロジェクタなど,さまざまな製品に搭載されています.小型,高精度,低消費電力という特徴を持つMEMSデバイスの応用分野は,今後さらに広がると期待されています.

本書は、MEMS技術の入門書であり、各種MEMSデバイスの動作原理や製造プロセス、応用について、わかりやすく説明しています、製造プロセスについては実際のMEMS工場の装置の写真を多用し、また応用については具体的な設計事例を紹介しています。

CQ出版社 〒170-8461 東京都豊島区巣鴨1-14-2 販売部 ☎ (03)5395-2141 振替 00100-7-10665